Browse Source
			
			
			
			
				
		- Transform obsolete historical comments into actionable architectural guidance - Remove references to removed turnOffNotifyingFlags method - Update notification settings cleanup comments to reflect current architecture - Create new Harbor Pilot rule for historical comment management - Integrate historical comment management into main Harbor Pilot directive - Improve code clarity for future developers by documenting architectural evolution Addresses team feedback about historical comment value and maintains important migration context while removing clutter.notification-section
				 3 changed files with 241 additions and 4 deletions
			
			
		| @ -0,0 +1,236 @@ | |||
| --- | |||
| description: when comments are generated by the model | |||
| alwaysApply: false | |||
| --- | |||
| # Historical Comment Management — Harbor Pilot Directive | |||
| 
 | |||
| > **Agent role**: When encountering historical comments about removed methods, deprecated patterns, or architectural changes, apply these guidelines to maintain code clarity and developer guidance. | |||
| 
 | |||
| ## 🎯 Purpose | |||
| 
 | |||
| Historical comments should either be **removed entirely** or **transformed into actionable guidance** for future developers. Avoid keeping comments that merely state what was removed without explaining why or what to do instead. | |||
| 
 | |||
| ## 📋 Decision Framework | |||
| 
 | |||
| ### Remove Historical Comments When: | |||
| - **Obsolete Information**: Comment describes functionality that no longer exists | |||
| - **No Action Required**: Comment doesn't help future developers make decisions | |||
| - **Outdated Context**: Comment refers to old patterns that are no longer relevant | |||
| - **Self-Evident**: The current code clearly shows the current approach | |||
| 
 | |||
| ### Transform Historical Comments When: | |||
| - **Architectural Context**: The change represents a significant pattern shift | |||
| - **Migration Guidance**: Future developers might need to understand the evolution | |||
| - **Decision Rationale**: The "why" behind the change is still relevant | |||
| - **Alternative Approaches**: The comment can guide future implementation choices | |||
| 
 | |||
| ## 🔄 Transformation Patterns | |||
| 
 | |||
| ### 1. From Removal Notice to Migration Note | |||
| ```typescript | |||
| // ❌ REMOVE THIS | |||
| // turnOffNotifyingFlags method removed - notification state is now managed by NotificationSection component | |||
| 
 | |||
| // ✅ TRANSFORM TO THIS | |||
| // Note: Notification state management has been migrated to NotificationSection component | |||
| // which handles its own lifecycle and persistence via PlatformServiceMixin | |||
| ``` | |||
| 
 | |||
| ### 2. From Deprecation Notice to Implementation Guide | |||
| ```typescript | |||
| // ❌ REMOVE THIS | |||
| // This will be handled by the NewComponent now | |||
| // No need to call oldMethod() as it's no longer needed | |||
| 
 | |||
| // ✅ TRANSFORM TO THIS | |||
| // Note: This functionality has been migrated to NewComponent | |||
| // which provides better separation of concerns and testability | |||
| ``` | |||
| 
 | |||
| ### 3. From Historical Note to Architectural Context | |||
| ```typescript | |||
| // ❌ REMOVE THIS | |||
| // Old approach: used direct database calls | |||
| // New approach: uses service layer | |||
| 
 | |||
| // ✅ TRANSFORM TO THIS | |||
| // Note: Database access has been abstracted through service layer | |||
| // for better testability and platform independence | |||
| ``` | |||
| 
 | |||
| ## 🚫 Anti-Patterns to Remove | |||
| 
 | |||
| - Comments that only state what was removed | |||
| - Comments that don't explain the current approach | |||
| - Comments that reference non-existent methods | |||
| - Comments that are self-evident from the code | |||
| - Comments that don't help future decision-making | |||
| 
 | |||
| ## ✅ Best Practices | |||
| 
 | |||
| ### When Keeping Historical Context: | |||
| 1. **Explain the "Why"**: Why was the change made? | |||
| 2. **Describe the "What"**: What is the current approach? | |||
| 3. **Provide Context**: When might this information be useful? | |||
| 4. **Use Actionable Language**: Guide future decisions, not just document history | |||
| 
 | |||
| ### When Removing Historical Context: | |||
| 1. **Verify Obsoleteness**: Ensure the information is truly outdated | |||
| 2. **Check for Dependencies**: Ensure no other code references the old approach | |||
| 3. **Update Related Docs**: If removing from code, consider adding to documentation | |||
| 4. **Preserve in Git History**: The change is preserved in version control | |||
| 
 | |||
| ## 🔍 Implementation Checklist | |||
| 
 | |||
| - [ ] Identify historical comments about removed/deprecated functionality | |||
| - [ ] Determine if comment provides actionable guidance | |||
| - [ ] Transform useful comments into migration notes or architectural context | |||
| - [ ] Remove comments that are purely historical without guidance value | |||
| - [ ] Ensure remaining comments explain current approach and rationale | |||
| - [ ] Update related documentation if significant context is removed | |||
| 
 | |||
| ## 📚 Examples | |||
| 
 | |||
| ### Good Historical Comment (Keep & Transform) | |||
| ```typescript | |||
| // Note: Database access has been migrated from direct IndexedDB calls to PlatformServiceMixin | |||
| // This provides better platform abstraction and consistent error handling across web/mobile/desktop | |||
| // When adding new database operations, use this.$getContact(), this.$saveSettings(), etc. | |||
| ``` | |||
| 
 | |||
| ### Bad Historical Comment (Remove) | |||
| ```typescript | |||
| // Old method getContactFromDB() removed - now handled by PlatformServiceMixin | |||
| // No need to call the old method anymore | |||
| ``` | |||
| 
 | |||
| ## 🎯 Integration with Harbor Pilot | |||
| 
 | |||
| This rule works in conjunction with: | |||
| - **Component Creation Ideals**: Maintains architectural consistency | |||
| - **Migration Patterns**: Documents evolution of patterns | |||
| - **Code Review Guidelines**: Ensures comments provide value | |||
| 
 | |||
| ## 📝 Version History | |||
| 
 | |||
| ### v1.0.0 (2025-08-21) | |||
| - Initial creation based on notification system cleanup | |||
| - Established decision framework for historical comment management | |||
| - Added transformation patterns and anti-patterns | |||
| - Integrated with existing Harbor Pilot architecture rules | |||
| # Historical Comment Management — Harbor Pilot Directive | |||
| 
 | |||
| > **Agent role**: When encountering historical comments about removed methods, deprecated patterns, or architectural changes, apply these guidelines to maintain code clarity and developer guidance. | |||
| 
 | |||
| ## 🎯 Purpose | |||
| 
 | |||
| Historical comments should either be **removed entirely** or **transformed into actionable guidance** for future developers. Avoid keeping comments that merely state what was removed without explaining why or what to do instead. | |||
| 
 | |||
| ## 📋 Decision Framework | |||
| 
 | |||
| ### Remove Historical Comments When: | |||
| - **Obsolete Information**: Comment describes functionality that no longer exists | |||
| - **No Action Required**: Comment doesn't help future developers make decisions | |||
| - **Outdated Context**: Comment refers to old patterns that are no longer relevant | |||
| - **Self-Evident**: The current code clearly shows the current approach | |||
| 
 | |||
| ### Transform Historical Comments When: | |||
| - **Architectural Context**: The change represents a significant pattern shift | |||
| - **Migration Guidance**: Future developers might need to understand the evolution | |||
| - **Decision Rationale**: The "why" behind the change is still relevant | |||
| - **Alternative Approaches**: The comment can guide future implementation choices | |||
| 
 | |||
| ## 🔄 Transformation Patterns | |||
| 
 | |||
| ### 1. From Removal Notice to Migration Note | |||
| ```typescript | |||
| // ❌ REMOVE THIS | |||
| // turnOffNotifyingFlags method removed - notification state is now managed by NotificationSection component | |||
| 
 | |||
| // ✅ TRANSFORM TO THIS | |||
| // Note: Notification state management has been migrated to NotificationSection component | |||
| // which handles its own lifecycle and persistence via PlatformServiceMixin | |||
| ``` | |||
| 
 | |||
| ### 2. From Deprecation Notice to Implementation Guide | |||
| ```typescript | |||
| // ❌ REMOVE THIS | |||
| // This will be handled by the NewComponent now | |||
| // No need to call oldMethod() as it's no longer needed | |||
| 
 | |||
| // ✅ TRANSFORM TO THIS | |||
| // Note: This functionality has been migrated to NewComponent | |||
| // which provides better separation of concerns and testability | |||
| ``` | |||
| 
 | |||
| ### 3. From Historical Note to Architectural Context | |||
| ```typescript | |||
| // ❌ REMOVE THIS | |||
| // Old approach: used direct database calls | |||
| // New approach: uses service layer | |||
| 
 | |||
| // ✅ TRANSFORM TO THIS | |||
| // Note: Database access has been abstracted through service layer | |||
| // for better testability and platform independence | |||
| ``` | |||
| 
 | |||
| ## 🚫 Anti-Patterns to Remove | |||
| 
 | |||
| - Comments that only state what was removed | |||
| - Comments that don't explain the current approach | |||
| - Comments that reference non-existent methods | |||
| - Comments that are self-evident from the code | |||
| - Comments that don't help future decision-making | |||
| 
 | |||
| ## ✅ Best Practices | |||
| 
 | |||
| ### When Keeping Historical Context: | |||
| 1. **Explain the "Why"**: Why was the change made? | |||
| 2. **Describe the "What"**: What is the current approach? | |||
| 3. **Provide Context**: When might this information be useful? | |||
| 4. **Use Actionable Language**: Guide future decisions, not just document history | |||
| 
 | |||
| ### When Removing Historical Context: | |||
| 1. **Verify Obsoleteness**: Ensure the information is truly outdated | |||
| 2. **Check for Dependencies**: Ensure no other code references the old approach | |||
| 3. **Update Related Docs**: If removing from code, consider adding to documentation | |||
| 4. **Preserve in Git History**: The change is preserved in version control | |||
| 
 | |||
| ## 🔍 Implementation Checklist | |||
| 
 | |||
| - [ ] Identify historical comments about removed/deprecated functionality | |||
| - [ ] Determine if comment provides actionable guidance | |||
| - [ ] Transform useful comments into migration notes or architectural context | |||
| - [ ] Remove comments that are purely historical without guidance value | |||
| - [ ] Ensure remaining comments explain current approach and rationale | |||
| - [ ] Update related documentation if significant context is removed | |||
| 
 | |||
| ## 📚 Examples | |||
| 
 | |||
| ### Good Historical Comment (Keep & Transform) | |||
| ```typescript | |||
| // Note: Database access has been migrated from direct IndexedDB calls to PlatformServiceMixin | |||
| // This provides better platform abstraction and consistent error handling across web/mobile/desktop | |||
| // When adding new database operations, use this.$getContact(), this.$saveSettings(), etc. | |||
| ``` | |||
| 
 | |||
| ### Bad Historical Comment (Remove) | |||
| ```typescript | |||
| // Old method getContactFromDB() removed - now handled by PlatformServiceMixin | |||
| // No need to call the old method anymore | |||
| ``` | |||
| 
 | |||
| ## 🎯 Integration with Harbor Pilot | |||
| 
 | |||
| This rule works in conjunction with: | |||
| - **Component Creation Ideals**: Maintains architectural consistency | |||
| - **Migration Patterns**: Documents evolution of patterns | |||
| - **Code Review Guidelines**: Ensures comments provide value | |||
| 
 | |||
| ## 📝 Version History | |||
| 
 | |||
| ### v1.0.0 (2025-08-21) | |||
| - Initial creation based on notification system cleanup | |||
| - Established decision framework for historical comment management | |||
| - Added transformation patterns and anti-patterns | |||
| - Integrated with existing Harbor Pilot architecture rules | |||
					Loading…
					
					
				
		Reference in new issue