summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSon Ho2022-01-29 21:29:13 +0100
committerSon Ho2022-01-29 21:29:13 +0100
commit158bdf6cb3083a2db3269b721b3815aa977cb824 (patch)
treefa2592367ba4d716de9bf92fe45ee0b9b5e059b1 /src
parentd36c5d1d0dc98a9e5fd1cfadd1981a5b99ff7d8d (diff)
Implement StringUtils.to_camel_case
Diffstat (limited to 'src')
-rw-r--r--src/StringUtils.ml25
1 files changed, 11 insertions, 14 deletions
diff --git a/src/StringUtils.ml b/src/StringUtils.ml
index 6089efc8..7c77a8d1 100644
--- a/src/StringUtils.ml
+++ b/src/StringUtils.ml
@@ -54,22 +54,20 @@ let string_to_chars (s : string) : char list =
(** This operates on ASCII *)
let to_camel_case (s : string) : string =
- (* There are no [fold_left_map] in [String]... *)
- let mk_upper = ref true in
- (* TODO: remove '_' *)
- let apply (c : char) : char =
- if !mk_upper then (
- mk_upper := c = '_';
- uppercase_ascii c)
- else (
- mk_upper := c = '_';
- c)
+ (* Note that we rebuild the string in reverse order *)
+ let apply ((prev_is_under, acc) : bool * char list) (c : char) :
+ bool * char list =
+ if c = '_' then (true, acc)
+ else
+ let c = if prev_is_under then uppercase_ascii c else c in
+ (false, c :: acc)
in
- String.map apply s
+ let _, chars = List.fold_left apply (true, []) (string_to_chars s) in
+ string_of_chars (List.rev chars)
(** This operates on ASCII *)
let to_snake_case (s : string) : string =
- (* Note that we rebuild the string in invert order *)
+ (* Note that we rebuild the string in reverse order *)
let apply ((prev_is_low, prev_is_digit, acc) : bool * bool * char list)
(c : char) : bool * bool * char list =
let acc =
@@ -90,7 +88,6 @@ let to_snake_case (s : string) : string =
(** Unit tests *)
let _ =
- assert (is_digit_ascii '3');
- assert (is_digit_ascii '6');
+ assert (to_camel_case "hello_world" = "HelloWorld");
assert (to_snake_case "HelloWorld36Hello" = "hello_world36_hello");
assert (to_snake_case "HELLO" = "hello")