package atd

  1. Overview
  2. Docs

Source file type_name.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
(*
   Utilities for manipulating type names, since they're not plain strings.
*)

type t = TN of string list

let compare = Stdlib.compare
let equal = Stdlib.(=)

let to_string (TN path) = String.concat "." path

let basename name =
  match name with
  | TN [base_name]
  | TN [_; base_name] -> base_name
  | TN [] -> invalid_arg "Type_name.basename: empty name"
  | TN (_ :: _ as path) -> List.rev path |> List.hd

let split name =
  match name with
  | TN [base_name] -> None, base_name
  | TN [local_module_name; base_name] -> Some local_module_name, base_name
  | TN [] -> invalid_arg "Type_name.split: empty name"
  | TN _ -> invalid_arg ("Type_name.split: more than two components in "
                         ^ to_string name)