-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathutils.ml
32 lines (28 loc) · 878 Bytes
/
utils.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
(*
* Copyright (c) 2015 Alexander Færøy. All rights reserved.
* Use of this source code is governed by a BSD-style
* license that can be found in the LICENSE file.
*)
let rec intersperse list element =
match list with
| [] | [_] -> list
| a :: b :: tail -> a :: element :: intersperse (b :: tail) element
let split s c =
let p = String.index s c in
let l = String.length s in
let first = String.sub s 0 p in
let second = String.sub s (p + 1) (l - p - 1) in
(first, second)
let prefix s c =
match (String.length s) with
| 0 -> false
| _ -> (String.get s 0) == c
let split_all s c =
let rec aux i acc =
match String.contains i c with
| true ->
let head, rest = split i c in
aux rest (head :: acc)
| false ->
List.rev (i :: acc) in
aux s []