No description
Find a file
Blaž Hrastnik 935cfeae57 Split parts of helix-term into helix-view.
It still largely depends on term for some types but I plan to change
that later.
2020-09-21 18:24:16 +09:00
.github/workflows Checkout submodules on clone. 2020-09-12 19:35:26 +09:00
helix-core Split parts of helix-term into helix-view. 2020-09-21 18:24:16 +09:00
helix-syntax cleanup: Import tree-sitter-highlight so we can cache trees. 2020-09-11 14:14:44 +09:00
helix-term Split parts of helix-term into helix-view. 2020-09-21 18:24:16 +09:00
helix-view Split parts of helix-term into helix-view. 2020-09-21 18:24:16 +09:00
.gitignore Incremental parsing: rough draft. 2020-09-17 16:32:40 +09:00
.gitmodules Add helix-syntax as a wrapper around tree-sitter parsers. 2020-09-09 14:41:12 +09:00
Cargo.lock Split parts of helix-term into helix-view. 2020-09-21 18:24:16 +09:00
Cargo.toml Split parts of helix-term into helix-view. 2020-09-21 18:24:16 +09:00
README.md Split parts of helix-term into helix-view. 2020-09-21 18:24:16 +09:00
TODO.md Refactor a little bit. 2020-09-12 17:44:57 +09:00

Helix

Crate Description
helix-core Core editing primitives, functional.
helix-syntax Tree-sitter grammars
helix-view UI abstractions for use in backends, imperative shell.
helix-term Terminal UI
  • server-client architecture via gRPC, UI separate from core
  • multi cursor based editing and slicing
  • WASM based plugins (builtin LSP & fuzzy file finder)
  • piece table-based tree structure for changes

Structure similar to codemirror:

text (ropes)

  • column utils, stuff like tab aware (row, col) -> char pos translation
  • word/grapheme/code point utils and iterators state
  • transactions
    • changes
    • annotations (time changed etc)
    • state effects
    • additional editor state as facets
  • snapshots as an async view into current state
  • selections { anchor (nonmoving), head (moving) from/to } -> SelectionSet with a primary
    • cursor is just a single range selection
  • markers track a position inside text that synchronizes with edits { doc, selection, update(), splice, changes(), facets, tabSize, identUnit, lineSeparator, changeFilter/transactionFilter to modify stuff before } view (actual UI)
  • renders via termwiz
  • viewport(Lines) -> what's actually visible
  • extend the view via Decorations (inline styling) or Components (UI)
    • mark / wieget / line / replace decoration commands (transform state)
  • movement
  • selection extension
  • deletion
  • indentation keymap (maps keys to commands) history (undo tree via immutable ropes)
  • undoes transactions
  • invert changes (generates a revert) (collab mode) gutter (line numbers, diagnostic marker, etc) -> ties into UI components rangeset/span -> mappable over changes (can be a marker primitive?) syntax (treesitter)
  • indentation strategies fold selections (select mode/multiselect) matchbrackets closebrackets special-chars (shows dots etc for specials) panel (for UI: file pickers, search dialogs, etc) tooltip (for UI) search (regex? pcre) lint (async linters) lsp highlight (?) stream-syntax autocomplete comment (gc, etc for auto commenting) snippets

terminal mode?

plugins can contain more commands/ui abstractions to use elsewhere

languageData as presets for each language (syntax, indent, comment, etc)

TODO: determine rust vs script portions

vim stuff: motions/operators/text objects full visual mode macros jump lists marks yank/paste conceal for markdown markers, etc


codemirror uses offsets exclusively with Line being computed when necessary (with start/end extents) lines are temporarily cached in a lineCache