LSP uses UTF-16 for indexing, so we need to provide some primitives to interact with Lean strings using UTF-16 indices.
Equations
Instances For
Computes the UTF-16 offset of the n
-th Unicode codepoint
in the substring of s
starting at UTF-8 offset off
.
Yes, this is actually useful.
Instances For
Instances For
Computes the position of the Unicode codepoint at UTF-16 offset
utf16pos
in the substring of s
starting at UTF-8 offset off
.
Equations
Instances For
Instances For
Starting at utf8pos
, finds the UTF-8 offset of the p
-th codepoint.
Equations
Instances For
Computes an UTF-8 offset into text.source
from an LSP-style 0-indexed (ln, col) position.
Equations
- One or more equations did not get rendered due to their size.
Instances For
Equations
- text.leanPosToLspPos { line := line, column := col } = { line := line - 1, character := text.source.codepointPosToUtf16PosFrom col (Lean.FileMap.lineStartPos✝ text (line - 1)) }
Instances For
Instances For
Gets the LSP range from a String.Range
.
Equations
- text.utf8RangeToLspRange range = { start := text.utf8PosToLspPos range.start, «end» := text.utf8PosToLspPos range.stop }
Instances For
Convert the Lean DeclarationRange
to an LSP Range
by turning the 1-indexed line numbering into a
0-indexed line numbering and converting the character offset within the line to a UTF-16 indexed
offset.
Equations
- r.toLspRange = { start := { line := r.pos.line - 1, character := r.charUtf16 }, «end» := { line := r.endPos.line - 1, character := r.endCharUtf16 } }