package sedlex
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >
  
  
  An OCaml lexer generator for Unicode
Install
    
    dune-project
 Dependency
Authors
Maintainers
Sources
  
    
      v3.7.tar.gz
    
    
        
    
  
  
  
    
  
  
    
  
        md5=893790268f68a1bb60dcc139f390a2d3
    
    
  sha512=053bceea4944309705e6b8014381711a2c4f7f0ab235cd239e2d2f5a2dbd3efe1b1c2d533631a8545dacf563cdb5b7469fe53982ef79ace270ee8a4a471f1fe2
    
    
  doc/src/sedlex_ppx/utf8.ml.html
Source file utf8.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49open Sedlexing let unsafe_byte s j = Char.code (String.unsafe_get s j) let malformed s j l = `Malformed (String.sub s j l) let r_utf_8 s j l = (* assert (0 <= j && 0 <= l && j + l <= String.length s); *) let uchar c = `Uchar (Uchar.unsafe_of_int c) in match l with | 1 -> uchar (unsafe_byte s j) | 2 -> ( let b0 = unsafe_byte s j in let b1 = unsafe_byte s (j + 1) in match Utf8.Helper.check_two b0 b1 with | i -> uchar i | exception MalFormed -> malformed s j l) | 3 -> ( let b0 = unsafe_byte s j in let b1 = unsafe_byte s (j + 1) in let b2 = unsafe_byte s (j + 2) in match Utf8.Helper.check_three b0 b1 b2 with | i -> uchar i | exception MalFormed -> malformed s j l) | 4 -> ( let b0 = unsafe_byte s j in let b1 = unsafe_byte s (j + 1) in let b2 = unsafe_byte s (j + 2) in let b3 = unsafe_byte s (j + 3) in match Utf8.Helper.check_four b0 b1 b2 b3 with | i -> uchar i | exception MalFormed -> malformed s j l) | _ -> assert false let fold ~f acc s = let rec loop acc f s i last = if i > last then acc else ( match Utf8.Helper.width (String.unsafe_get s i) with | exception MalFormed -> loop (f acc i (malformed s i 1)) f s (i + 1) last | need -> let rem = last - i + 1 in if rem < need then f acc i (malformed s i rem) else loop (f acc i (r_utf_8 s i need)) f s (i + need) last) in let pos = 0 in let len = String.length s in let last = pos + len - 1 in loop acc f s pos last
 sectionYPositions = computeSectionYPositions($el), 10)"
  x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
  >