123456789101112131415161718192021222324252627282930313233343536373839404142434445464748(*
* Copyright (c) 2013-2022 Thomas Gazagnaire <thomas@gazagnaire.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*)openAstringincludePath_intfmoduleString_list=structtypestep=string[@@derivingirmin]typet=steplistletempty=[]letis_emptyl=l=[]letconsst=s::tletrconsts=t@[s]letdecons=function[]->None|h::t->Some(h,t)letrdeconsl=matchList.revlwith[]->None|h::t->Some(List.revt,h)letmaplf=List.mapflletvx=xletppppft=letlen=List.fold_left(funaccs->1+acc+String.lengths)1tinletbuf=Buffer.createleninList.iter(funs->Buffer.add_charbuf'/';Buffer.add_stringbufs)t;Fmt.stringppf(Buffer.contentsbuf)letof_strings=Ok(List.filter((<>)"")(String.cutss~sep:"/"))lett=Type.like~pp~of_stringType.(liststep_t)end