LSP uses UTF-16 for indexing, so we need to provide some primitives to interact with Lean strings using UTF-16 indices.
Equations
- Char.utf16Size c = if c.val ≤ 65535 then 1 else 2
Instances For
Equations
- String.utf16Length s = String.foldr (fun (c : Char) (acc : Nat) => String.csize16 c + acc) 0 s
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.
Equations
- String.codepointPosToUtf16PosFrom s n off = String.codepointPosToUtf16PosFromAux s n off 0
Instances For
Equations
- String.codepointPosToUtf16Pos s pos = String.codepointPosToUtf16PosFrom s pos 0
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
- String.utf16PosToCodepointPosFrom s utf16pos off = String.utf16PosToCodepointPosFromAux s utf16pos off 0
Instances For
Equations
- String.utf16PosToCodepointPos s pos = String.utf16PosToCodepointPosFrom s pos 0
Instances For
Starting at utf8pos
, finds the UTF-8 offset of the p
-th codepoint.
Equations
- String.codepointPosToUtf8PosFrom s x 0 = x
- String.codepointPosToUtf8PosFrom s x (Nat.succ p) = String.codepointPosToUtf8PosFrom s (String.next s x) p
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
- One or more equations did not get rendered due to their size.
Instances For
Equations
- Lean.FileMap.utf8PosToLspPos text pos = Lean.FileMap.leanPosToLspPos text (Lean.FileMap.toPosition text pos)