diff options
-rw-r--r-- | lib/jid.ml | 19 |
1 files changed, 11 insertions, 8 deletions
@@ -32,23 +32,26 @@ let string_of_uchars (u : uchars) = let of_string (s : string) : t = let open List in let jid = uchars_of_string s in - let dend, resourcepart = + let rest, resourcepart = find_mapi (fun i c -> if c = Uchar.of_char '/' - then Some (i, drop i jid |> string_of_uchars) + then Some (take i jid, drop (i+1) jid |> string_of_uchars) else None) jid - |> Option.fold ~none:(length jid, None) ~some:(fun (i, s) -> i, Some s) - and dlen, localpart = - rev jid + |> Option.fold ~none:(jid, None) ~some:(fun (rest, res) -> rest, Some res) + in + let localpart, domainpart = + rev rest |> find_mapi (fun i c -> if c = Uchar.of_char '@' - then Some (i, take (length jid - i - 1) jid |> string_of_uchars) + then let idx = length rest - i + in Some (take (idx-1) rest |> string_of_uchars, + drop idx rest |> string_of_uchars) else None) - |> Option.fold ~none:(0, None) ~some:(fun (i, s) -> i, Some s) + |> Option.fold ~none:(None, rest |> string_of_uchars) ~some:(fun (loc, dom) -> Some loc, dom) in { localpart; resourcepart; - domainpart = drop (dend-dlen) jid |> take dlen |> string_of_uchars + domainpart; } let%expect_test {|A "bare JID"|} = |