package reason

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Source file eol_convert.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
open Eol_detect

let lf_to_crlf s =
  let rec loop sz =
    match String.index sz '\n' with
    | exception Not_found -> sz
    | idx ->
      let l = String.sub sz 0 idx ^ "\r\n" in
      let length = String.length sz in
      l ^ loop (String.sub sz (idx + 1) (length - idx - 1))
  in
  loop s

let get_formatter output_channel eol =
  let f = Format.formatter_of_out_channel output_channel in
  let out_functions = Format.pp_get_formatter_out_functions f () in
  let out_string s p n =
    match eol with
    | LF -> out_functions.out_string s p n
    | CRLF ->
      let str = String.sub s p n in
      let str = lf_to_crlf str in
      out_functions.out_string str 0 (String.length str)
  in
  let new_functions = { out_functions with out_string } in
  Format.pp_set_formatter_out_functions f new_functions;
  f
OCaml

Innovation. Community. Security.