12345678910111213141516171819202122232425262728293031openCoreincludeUtilitytypet=intlist(* for Set.Elt *)letcomparexy=List.compareStdlib.comparexyletsexp_of_t=List.sexp_of_tSexplib.Conv.sexp_of_intlett_of_sexp=List.t_of_sexpSexplib.Conv.int_of_sexpletempty()=[]letsortl=List.sort~compare:Stdlib.comparelletuniql=List.dedup_and_sort~compare:Stdlib.comparelletof_char_listl=letrecreadlistlg=matchlwith|[]->g|c::cs->matchcwith|'a'..'z'->readlistcs((from_lowerc)::g)|'A'..'Z'->readlistcs((from_upperc)::g)|_->readlistcsginuniq(readlistl[])letof_strings=of_char_list(String.to_list_revs)letcontainssc=List.memsc