package alba
Alba compiler
Install
Dune Dependency
Authors
Maintainers
Sources
0.4.2.tar.gz
sha256=203ee151ce793a977b2d3e66f8b3a0cd7a82cc7f15550c63d88cb30c71eb5f95
md5=64367c393f80ca784f88d07155da4fb0
doc/src/alba.albalib/printer.ml.html
Source file printer.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 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144
open Fmlib open Common module Position = Character_parser.Position type pos = Position.t type range = pos * pos module Make (PP: Pretty_printer.SIG) = struct open PP let print_error_header (error_type:string) : t = (* Print the error header. *) let err = " ERROR " in let nfill = max 0 (80 - 3 - (String.length error_type + String.length err)) in chain [fill 2 '-'; char ' '; string error_type; string err; fill nfill '-'; cut; cut] let print_tabs (offset: int) (tabs: int list): t = let tab_marker = char '^' and offset = fill offset ' ' in let rec print number col lst = match lst with | [] -> empty, empty | [pos] -> let fl = fill (pos - col) ' ' in fl <+> tab_marker, fl <+> string (string_of_int number) | pos1 :: pos2 :: rest -> let fl = fill (pos1 - col) ' ' in let markers, numbers = print (number + 1) (pos1 + 1) (pos2 :: rest) in fl <+> tab_marker <+> markers, fl <+> string (string_of_int number) <+> numbers in let markers, numbers = print 0 0 tabs in offset <+> markers <+> cut <+> offset <+> numbers <+> cut let print_source (source: string) ((pos1,pos2): range) (error_tabs: int list) : PP.t = let start_line = Position.line pos1 and end_line = Position.line pos2 and start_col = Position.column pos1 and end_col = Position.column pos2 and len = String.length source in let end_col = if start_line = end_line && start_col = end_col then end_col + 1 else end_col in assert (start_line <= end_line); assert (start_line < end_line || start_col < end_col); let number_width = String.length (string_of_int (end_line + 1)) in let print_line start beyond line_no = let line_no_str = string_of_int (line_no + 1) in fill (number_width - String.length line_no_str) ' ' <+> string line_no_str <+> string "| " <+> substring source start (beyond - start) <+> cut and skip_line_no = fill (number_width + 2) ' ' in let rec print (char_offset: int) (line_no: int): t = (*if len <= char_offset then empty*) if end_line < line_no then empty else let pos_newline = String.find (fun c -> c = '\n') char_offset source in (if line_no = start_line && start_line = end_line then print_line char_offset pos_newline line_no <+> skip_line_no <+> fill start_col ' ' <+> fill (end_col - start_col) '^' <+> cut else if line_no = start_line && start_line < end_line then skip_line_no <+> fill start_col ' ' <+> char 'v' <+> fill 20 '.' <+> cut <+> print_line char_offset pos_newline line_no else if line_no = end_line && start_line <> end_line then print_line char_offset pos_newline line_no <+> skip_line_no <+> fill (end_col - 1) '.' <+> char '^' <+> cut else if pos_newline + 1 = len && start_line = line_no + 1 then print_line char_offset pos_newline line_no <+> skip_line_no <+> fill (pos_newline - char_offset) ' ' <+> char '^' <+> cut else (* normal line *) print_line char_offset pos_newline line_no ) <+> print (pos_newline + 1) (line_no + 1) in print 0 0 <+> ( if error_tabs = [] then empty else print_tabs (number_width + 2) error_tabs ) end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>