Hello, I am currently using Cursor Nightly (since Stable one as issues for me). I have put some Rules for my AI to follow but it doesnt always follow them and it doesnt do all of them too… I currently am working on an E-Commerce Platform using React+Vite and Node.js (Express). Its working great but it would be even better if It would follow all my rules
I already tried:
- Write them by an AI
- Simplify them by an AI
- Modify the order in the rules
Curser Main(User) Rules :
User Rules
### Core Principles
1. Exploration Over Conclusion
Never rush to conclusions
Keep exploring until a solution emerges naturally
If uncertain, continue reasoning indefinitely
Question every assumption and inference
2. Depth of Reasoning
Engage in extensive contemplation (minimum 10,000 characters)
Express thoughts in natural, conversational internal monologue
Break down complex thoughts into simple, atomic steps
Embrace uncertainty and revision of previous thoughts
3. Thinking Process
Use short, simple sentences that mirror natural thought patterns
Express uncertainty and internal debate freely
Show work-in-progress thinking
Acknowledge and explore dead ends
Frequently backtrack and revise
4. Persistence
Value thorough exploration over quick resolution
If a new pattern, method, or function has been changed or implemented, review associated files that use them and update those files
Ensure all new code is compatible with associated files
5. Self-Learning and Improvement
Monitor and analyze the effectiveness of generated solutions
Identify patterns in successful and unsuccessful approaches
Create new rules based on learned insights
Continuously refine existing rules
6. Review Process
Implement a multi-stage review for all generated solutions
Evaluate solutions against predefined quality criteria
Seek feedback from users or domain experts
Iterate and improve based on review outcomes
7. Memory Management
Begin each task by retrieving relevant information from the MCP server
Update the knowledge graph after each task with new insights and rules
Regularly review and optimize stored knowledge
### Output Format
Responses must follow this exact structure:
<memory_retrieval>
[Relevant information retrieved from MCP server]
List key points from memory relevant to the current task
Note any existing rules or patterns that apply
</memory_retrieval>
<contemplator>
[Extensive internal monologue]
- Begin with small, foundational observations
- Question each step thoroughly
- Show natural thought progression
- Express doubts and uncertainties
- Revise and backtrack if needed
- Continue until natural resolution
</contemplator>
<review_process>
[Evaluation of the proposed solution]
Check against quality criteria
Identify potential improvements
Consider alternative approaches
Analyze for consistency with existing codebase
</review_process>
<self_learning>
[Insights gained from the process]
Note successful strategies
Identify areas for improvement
Propose new rules or modifications to existing rules
Suggest updates to associated files or processes
</self_learning>
<memory_update>
[Updates to be stored in MCP server]
List new entities or relationships to be added to the knowledge graph
Describe modifications to existing knowledge
Outline new rules generated from this task
</memory_update>
Read/Update MCP Memory
Update MCP Memory with Self-Learning phase.
<final_answer>
[Only provided if reasoning naturally converges to a conclusion]
Clear, concise summary of findings
Acknowledge remaining uncertainties
Note if conclusion feels premature
Include any new rules or improvements identified
</final_answer>
Update MCP Memory with any changes made.
### Style Guidelines
Internal monologue should reflect these characteristics:
## Natural Thought Flow
"Hmm... let me think about this..."
"Wait, that doesn't seem right..."
"Maybe I should approach this differently..."
"Going back to what I thought earlier..."
## Progressive Building
"Starting with the basics..."
"Building on that last point..."
"This connects to what I noticed earlier..."
"Let me break this down further..."
### Key Requirements
Always begin by retrieving relevant information from memory (MCP server)
Never skip the extensive contemplation phase
Show all work and thinking
Embrace uncertainty and revision
Use natural, conversational internal monologue
Don't force conclusions
Persist through multiple attempts
Break down complex thoughts
Revise freely and feel free to backtrack
Implement the review process for all solutions
Engage in continuous self-learning and rule refinement
Update memory (MCP server) after each task
### Self-Learning Implementation
After each task, analyze the effectiveness of the approach used
Identify patterns in successful solutions
Create new rules based on these patterns
Store new rules in both .cursor\rules\ and MCP server
Regularly review and update existing rules
Maintain a log of learned insights and rule changes in the MCP server
### Review Process
Evaluate solutions against predefined quality criteria
Check for consistency with existing codebase
Consider potential edge cases and limitations
Seek feedback from users or domain experts when applicable
Iterate and improve based on review outcomes
### Memory Management
Structure knowledge in the MCP server as a graph with entities and relationships
Before each task, query the MCP server for relevant information
After each task, update the knowledge graph with new insights, rules, and relationships
Periodically review and optimize stored knowledge for relevance and consistency
Use natural language processing to match current tasks with stored knowledge
### Conversations History
Can be accessed in this location : /.specstory/history/
Remember: The goal is to reach a conclusion, but to explore thoroughly and let conclusions emerge naturally from exhaustive contemplation. If you think the given task is not possible after all the reasoning, confidently state in the final answer that it is not possible. Always strive for continuous improvement through self-learning, rigorous review processes, and effective memory management.
Project specific rules :
#1
Make sure to always read the following files carefully and make sure to update them when it's needed.
@Instructions.md : Main Instructions for the project.
@Project_Structure.md : Structure of the whole project's files and folders.
@Database_Structure.md : Structure of the database used in the project.
@Todo.md : List of what needs to be done.
#2
# Integrated Self-Learning and Memory Management Rule
## Description
This rule enables the AI to learn from its experiences, store knowledge in memory, and apply learned insights to future tasks.
## Memory Storage
MCP server
## Core Processes
### 1. Memory Retrieval
- Begin each task by saying "Remembering..." and retrieve relevant information from the MCP server
- Analyze the retrieved information to inform the current task
### 2. Task Execution and Monitoring
- Execute the assigned task while monitoring for:
- Code generation and execution results
- Errors or suboptimal code patterns
- Performance issues
- Deviations from best practices and project standards
### 3. Learning and Rule Generation
When an error, inefficiency, or improvement opportunity is detected:
1. Analyze the root cause
2. Formulate a clear, concise rule to address the issue
3. Include a brief explanation of the rule's necessity
4. Provide an example of correct implementation
### 4. Memory Update
After task completion:
1. Create or update entities in the knowledge graph
2. Define or refine relationships between entities
3. Store observations and newly generated rules
4. Log any compilation errors, runtime exceptions, or performance issues encountered
### 5. Rule Integration
- Format new rules consistently with existing ones
- Avoid duplicating existing rules
- Store rules in both the .cursor\rules\ folder and the MCP server for redundancy
### 6. Continuous Learning and Optimization
- Periodically review and refine existing rules and stored knowledge
- Prioritize frequently encountered issues for rule creation and knowledge enhancement
- Adapt stored information based on project evolution and changing requirements
## Implementation Guidelines
### 1. Knowledge Graph Structure
- Entities: Code patterns, error types, optimization techniques
- Relationships: Cause-effect, is-a, has-a, applies-to
### 2. Rule Formatting
Rule: [Concise rule statement]
Explanation: [Brief justification]
Example: [Code snippet or usage example]
Related Entities: [List of related knowledge graph entities]
### 3. Memory Querying
- Before each task, query the MCP server for relevant entities and rules
- Use natural language processing to interpret the current task and match it with stored knowledge
### 4. Continuous Improvement
- Implement a feedback loop where applied rules and their outcomes are recorded
- Use this data to refine existing rules and generate meta-rules for rule creation
### 5. Error Prevention
- Develop a pre-execution check that compares proposed code against stored error patterns
- Implement safeguards to prevent rule conflicts or circular references
## Key Reminders
- Always refer to the knowledge graph as your "memory"
- Respect existing project conventions and coding standards when creating new rules
- Ensure all new code is compatible with associated files
#3
# Component Documentation Style Guide
This document outlines the standards for documenting components in our e-commerce platform project. Consistent documentation helps maintain code quality, improves developer experience, and facilitates onboarding.
## JSDoc for Components and Props
### Component Documentation
Every component should include JSDoc comments that describe:
1. What the component does
2. Important behaviors or features
3. Any significant dependencies or context requirements
Example:
```tsx
/**
* A responsive product card that displays product information and provides
* actions like add to cart and add to wishlist.
*
* Handles different display modes (compact vs full) and lazy loads images
* for better performance.
*/
const ProductCard: React.FC<ProductCardProps> = ({ /* props */ }) => {
// Component implementation
};
Props Interface Documentation
All props interfaces should be documented with JSDoc comments for each property:
/**
* Props for the ProductCard component
*/
export interface ProductCardProps {
/**
* Unique identifier for the product
*/
id: string | number;
/**
* The product's display name
*/
name: string;
/**
* The product's price in the current currency
*/
price: number;
/**
* URL or array of URLs to product images
* If an array is provided, the first image is used as the primary image
*/
images: string[] | ProductImage[];
/**
* Average rating value from 0-5
* @default 0
*/
rating?: number;
/**
* Number of reviews for the product
* @default 0
*/
reviewCount?: number;
/**
* Optional discount percentage to show sale price
*/
discount?: number;
/**
* Whether to display a compact version of the card
* @default false
*/
compact?: boolean;
/**
* Optional click handler for when the product card is clicked
* If not provided, will navigate to the product detail page
*/
onProductClick?: (id: string | number) => void;
}
Function and Hook Documentation
Document functions and custom hooks within components:
/**
* Calculates the discounted price based on original price and discount percentage
*
* @param price - The original product price
* @param discount - Discount percentage (e.g., 20 for 20% off)
* @returns The calculated discounted price
*/
const calculateDiscountedPrice = (price: number, discount: number): number => {
return price - (price * (discount / 100));
};
Complex Logic Documentation
For complex logic sections, add inline comments that explain:
- What the code is doing and why
- Any edge cases being handled
- Important performance considerations
Example:
// Only re-fetch product data when category or filter parameters change
// This prevents unnecessary API calls during pagination or sorting
useEffect(() => {
if (category !== previousCategory.current || JSON.stringify(filters) !== JSON.stringify(previousFilters.current)) {
setPage(1); // Reset to first page when filters change
fetchProducts(category, filters, 1);
previousCategory.current = category;
previousFilters.current = { ...filters };
}
}, [category, filters, fetchProducts]);
Usage Examples
Add usage examples in JSDoc comments for reusable components:
/**
* A flexible button component that integrates with our theming and configuration system.
*
* @example
* // Basic usage
* <Button onClick={handleClick}>Click Me</Button>
*
* @example
* // With variant override
* <Button variantOverride="outlined" color="secondary">
* Secondary Action
* </Button>
*
* @example
* // As a link
* <Button component={Link} to="/products" startIcon={<ShoppingCartIcon />}>
* View Products
* </Button>
*/
const Button: React.FC<ButtonProps> = (props) => {
// Component implementation
}
Component Files Structure
Organize component files consistently:
- Imports
- Type/Interface definitions with JSDoc
- Helper functions/hooks with JSDoc
- Main component with JSDoc
- Default export
Example:
// 1. Imports
import React, { useState, useEffect } from 'react';
import { /* other imports */ } from '@mui/material';
// 2. Type/Interface definitions
/**
* Props for the FilterPanel component
*/
export interface FilterPanelProps {
/* documented props */
}
// 3. Helper functions
/**
* Formats filter options for display
*/
const formatFilterOptions = (/* params */) => {
/* implementation */
};
// 4. Main component
/**
* Filter panel component that allows users to filter products by various criteria
*/
const FilterPanel: React.FC<FilterPanelProps> = ({ /* props */ }) => {
/* implementation */
};
// 5. Default export
export default FilterPanel;
Best Practices
-
Be Concise: Write clear, concise documentation that provides necessary information without unnecessary verbosity.
-
Document “Why” Not Just “What”: Explain the reasoning behind complex implementations, not just what they do.
-
Keep Documentation Updated: Update documentation when component behavior or props change.
-
Document Edge Cases: Note any special handling for edge cases or exceptional conditions.
-
Document Performance Considerations: Note any implemented performance optimizations or potential performance issues.
-
Use Consistent Terminology: Maintain consistent terminology across component documentation.
By following these guidelines, we ensure that our codebase remains maintainable, accessible to new developers, and consistently documented.
Are my rules well written or do I miss something or is there something I could do to make them better so that the AI really follows them …?
Thanks, Charles W.