You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Implement the visual display system for Line Annotations in the source editor. These annotations should appear directly beneath relevant lines of code and visually communicate messages such as errors, warnings, or informational notes.
Requirements
Add support for displaying annotations below lines in the source editor
An annotation should include:
A severity icon (error, warning, info)
A short descriptive message
Multiple annotations should be stackable if they occur on the same line
Styling should reflect severity (e.g., color, icon)
Annotations should update cleanly when the underlying data model changes (insert, remove, update)
Annotations should avoid disrupting layout:
Automatically shrink if needed to preserve line spacing.
If the message is truncated, allow users to click the annotation to reveal a popover with the full message.
This popover should scroll with the editor and remain positioned relative to its line.
If the line scrolls out of view and the annotation is expanded, the popover should remain visible—docked to the top or bottom edge of the editor—until dismissed.
Implementation Details
The expanded popover view (when multiple annotations exist or a message is truncated) may be called AnnotationAggregatedDropdownView, similar to what is used in other macOS editors.
The source editor (CodeEditSourceEditor) will accept a new property:
annotations: Set<LineAnnotation>
LineAnnotation is a lightweight data model that represents a message to display beneath a specific line:
structLineAnnotation:Hashable,Identifiable{letid:UUID=UUID()letline:Intletcolumn:Intletseverity:Severitylettext:String}enumSeverity{case error, warning, info, live
}
The editor should group annotations by line internally and render them accordingly.
Additional Context
This is the foundational work for visual feedback in the editor. Future issues will introduce the system for feeding issues into the annotations (e.g., from builds, linters, or language servers) via an issue manager.
This feature is a key part of improving the editing experience by surfacing issues contextually, and sets the stage for deeper diagnostic and development tooling integration.
Description
Implement the visual display system for Line Annotations in the source editor. These annotations should appear directly beneath relevant lines of code and visually communicate messages such as errors, warnings, or informational notes.
Requirements
Implementation Details
CodeEditSourceEditor
) will accept a new property:Additional Context
This is the foundational work for visual feedback in the editor. Future issues will introduce the system for feeding issues into the annotations (e.g., from builds, linters, or language servers) via an issue manager.
This feature is a key part of improving the editing experience by surfacing issues contextually, and sets the stage for deeper diagnostic and development tooling integration.
Related Issues
Screenshots
Warning

Warning Expanded

Error

Multiple Errors

Multiple Errors Expanded

The text was updated successfully, but these errors were encountered: