Open
Description
Description
Code folding allows developers to collapse and expand sections of code (such as functions, classes, conditionals, and comments) to reduce visual clutter and focus on the parts they’re working on. This feature is particularly useful when navigating large files or deeply nested structures.
Proposed Behavior
- Enable folding for code blocks such as:
- Functions and methods
- Classes and structs
- Loops and conditionals
- Multi-line comments and regions
- Display a vertical folding ribbon in the gutter next to line numbers, where users can click to collapse or expand blocks.
- Collapsed blocks should show an inline indicator with an expand toggle.
- Optionally, include editor commands for fold all / unfold all.
Implementation Notes
- Can be powered by the existing Tree-sitter syntax trees to determine foldable ranges based on code structure.
- Should maintain fold state across file/tab switches and ideally across sessions.
- Folding ribbon interactions should be smooth and intuitive, with hover states and visual cues.
- Should add animation for folding and unfolding to make transitions feel natural and responsive.
Benefits
- Reduces visual noise and helps maintain focus while editing.
- Makes it easier to navigate and manage large files.
- Provides a cleaner overview of structural code layout.
Additional Context
The folding ribbon provides a familiar and discoverable UI for interacting with folded sections and complements keyboard or menu-based folding commands.
Screenshots
Screen.Recording.2022-04-24.at.8.32.40.AM.mov
In Progress TODOs
- Fold Ribbon
- Draw nested folds
- Draw adjacent folds with a horizontal line (instead of overlapping rounded edges)
- Draw folded ranges
- Fold Model
- Generate folds from a provider for a document
- Update folds as a document is edited
- Fold Providers
- Line indent provider
- TreeSitter provider
- Perform Folding
- Draw text attachment for fold range
- Animate folded text
Metadata
Metadata
Assignees
Labels
Type
Projects
Status
🏃♂️ In Progress