diff options
| author | Maxime Dénès | 2017-02-15 13:58:45 +0100 |
|---|---|---|
| committer | Maxime Dénès | 2017-02-15 13:58:45 +0100 |
| commit | 0df095ec0715f548180bbff70a6feb673c6726a6 (patch) | |
| tree | d5518ea65638cc486aeeb652530b725925e96d98 /lib | |
| parent | 4fd59386e7f60d16bfe9858c372b354d422ac0b6 (diff) | |
| parent | 3cdcad29ee9d28b0cb39740004da90a0fe291543 (diff) | |
Merge PR#314: Miscellaneous fixes for Ocaml warnings.
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/unicode.ml | 24 |
1 files changed, 4 insertions, 20 deletions
diff --git a/lib/unicode.ml b/lib/unicode.ml index ced5e258c2..959ccaf73c 100644 --- a/lib/unicode.ml +++ b/lib/unicode.ml @@ -124,27 +124,11 @@ exception End_of_input let utf8_of_unicode n = if n < 128 then String.make 1 (Char.chr n) - else if n < 2048 then - let s = String.make 2 (Char.chr (128 + n mod 64)) in - begin - s.[0] <- Char.chr (192 + n / 64); - s - end - else if n < 65536 then - let s = String.make 3 (Char.chr (128 + n mod 64)) in - begin - s.[1] <- Char.chr (128 + (n / 64) mod 64); - s.[0] <- Char.chr (224 + n / 4096); - s - end else - let s = String.make 4 (Char.chr (128 + n mod 64)) in - begin - s.[2] <- Char.chr (128 + (n / 64) mod 64); - s.[1] <- Char.chr (128 + (n / 4096) mod 64); - s.[0] <- Char.chr (240 + n / 262144); - s - end + let (m,s) = if n < 2048 then (2,192) else if n < 65536 then (3,224) else (4,240) in + String.init m (fun i -> + let j = (n lsr ((m - 1 - i) * 6)) land 63 in + Char.chr (j + if i = 0 then s else 128)) (* If [s] is some UTF-8 encoded string and [i] is a position of some UTF-8 character within [s] |
