package coq-lsp

  1. Overview
  2. Docs
Language Server Protocol native server for Coq

Install

dune-project
 Dependency

Authors

Maintainers

Sources

coq-lsp-0.1.9.8.18.tbz
sha256=99514bcbf82318b9ff857656f4ec1f87bb46f1c699a4f1e9fb06f5fcdd8d8839
sha512=fa4593a2ae416e554869a879da5d35a1d33efa5cc8743f77c05373875ecea267019989dec600d5e880d909aea97ce7f6990ac59e58aabce358e3693b0764bef8

doc/coq-lsp.lang/Lang/Utf/index.html

Module Lang.UtfSource

This module provides facilities for translating language-based locations to protocol-based locations.

After a long discussion (thanks Léo !), we have decided that the best is to have `Lang.Point` to store columns offset in the values that are native to the protocol under consideration, set by the upper layers.

This scheme kind of follows what we have done since the start with coq-lsp.

Sourcemodule Encoding : sig ... end

Future work: support setting protocol enconding

Unicode terminology refresher:

  • character, code point: The real unicode character
  • byte or 16bit offset / code unit: The encoded version
Sourcetype utf8_string = string
Sourcetype char = int
Sourcetype utf8_index = int
Sourcetype utf16_index = int
Sourceval utf16_offset_of_utf8_offset : line:utf8_string -> offset:utf8_index -> utf16_index

UTF-16 offset from UTF-8 offset; line is enconded in UTF-8

Sourceval utf8_offset_of_utf16_offset : line:utf8_string -> offset:utf16_index -> utf8_index

Get the byte position of a code point indexed in UTF-16 code units in a UTF-8 encoded utf8_string. Returns the position of the last character if the UTF-16 position was out of bounds.

To UTF-16 offsets

Sourceval length_utf16 : utf8_string -> utf16_index

Length in UTF-16 code points

Not used anywhere, remove?

Sourceval length : utf8_string -> char

Number of characters in the utf-8-encoded utf8_string.

Converstion from char to UTF-8/16

Sourceval utf8_offset_of_char : line:utf8_string -> char:char -> utf8_index option

UTF-8 Char to byte index position; line is enconded in UTF-8

Sourceval utf16_offset_of_char : line:utf8_string -> char:int -> utf16_index

Get the utf16 position of a code point indexed in unicode code points in a UTF-8 encoded utf8_string. The position must be in bounds.

Converstion to char from UTF-8/16

Sourceval char_of_utf8_offset : line:utf8_string -> offset:utf8_index -> char option

Byte index to character position also called a codepoint, line is encoded in UTF-8

Sourceval char_of_utf16_offset : line:utf8_string -> offset:utf16_index -> char

Get the unicode position of a code point indexed in UTF-16 code units in a utf-8 encoded utf8_string. Returns the position of the last character if the utf-16 position was out of bounds.

Sourceval next : string -> int -> int

For testing